oracle 实现 关联两个表更新 update select

您所在的位置:网站首页 update 两个表 oracle 实现 关联两个表更新 update select

oracle 实现 关联两个表更新 update select

2024-07-16 00:02:29| 来源: 网络整理| 查看: 265

需求:

       有两张表A,B。表A和表B有共同的字段,id,dev_ip,collector_id. 其中id是作为两个表关联的唯一标识。即表A中的id与表B中的id是一一对应的。本来B表中的字段collector_id应该是完全一致的,但是由于某些原因B表中的collect_id值被修改了,现在需要将A,B表的collector_id同步成一致。即将A表中与B表id和dev_ip一样的数据行更新B表中的collector_id为A表中的collector_id值。

 

实现方法有以下几种:

tb_device_info表为B表,tb_device表为A表

方法一:

    update tb_device_info di set collectorid = (select d.collector_id from tb_device d where d.id = di.deviceid )  where deviceid =  (select d.id from  tb_device d where d.id = di.deviceid and di.collectorid d.collector_id)

 

方法二:道理同方法一。

  

    update tb_device_info di set collectorid = (select d.collector_id from tb_device d where d.id = di.deviceid )  where (select 1  from  tb_device d where d.id = di.deviceid and di.collectorid d.collector_id)

 

方法三:原理是更新已查条件结果集,相当于更新同一个表中的两个不同字段。

    update (select di.deviceid ,di.dev_ip ,di.collectorid ,d.id ,d.dev_ip ,d.collector_id from tb_device_info di ,tb_device d where di.deviceid = d.id and di.collectorid d.collector_id) set collectorid= collector_id 

 

 方法四:存储过程的方式

declare  cursor cur_collecot is select collector_id,id from tb_device;     begin            for my_cur in cur_collecot loop             update tb_devic_info set collectorid  = my_cur.collector_id                 where deviceid = my_cur.id;        end loop; 

 

以上方法参考网络文章终结,记录以备使用

另转载网络牛人原文

 

 

为了做分析,需要整合一些数据到一个表中,涉及到通过主键关联多个表,获取其中的某些字段的值,通过update可以简单实现,找了一篇文章,挺不错:

    批量更新表时,update一个表的列时,需要依赖另外的表,这种依赖可以是where条件子句,也可以要update的field的值依赖另外的表   通常有两种做法   1.使用存储过程   2.在程序代码里逐条循环执行这里给出一种更高效、简洁的做法,批量更新SQL ,一句SQL就可以替代麻烦的循环过程,有MS SQLServer、Oracle、DB2下的写法--关键点:t4和t1是同一个table,primary key肯定也是同一个,--并以它进行关联,这样在 select语句里即可引用到要update的表的fields UPDATE Table1 AS t1 SET (Field1,Field2) = (SELECT Field21, Field22                        FROM Table2 t2                             INNER JOIN Table3 t3                                  ON t3.Field31 = t2.Field23                             INNER JOIN Table4 t4                                  ON t3.Field32 = t4.Filed41                        WHERE t2.Field24 >= ''                                       AND t1.fId = t4.fId); ----------------------------MS SQLServer --------------------------------------

UPDATE t1 SET Field1 = Field21, Field2 = Field22 FROM Table2 t2          INNER JOIN Table3 t3               ON t3.Field31 = t2.Field23          INNER JOIN Table4 t4               ON t3.Field32 = t4.Filed41 WHERE ((t2.Field24 >= '')                   AND t1.fId = t4.fId); ----------------------------Oracle --------------------------------------------

UPDATE Table1 t1 SET (Field1,Field2) = (SELECT Field21, Field22                        FROM Table2 t2                             INNER JOIN Table3 t3                                  ON t3.Field31 = t2.Field23                             INNER JOIN Table4 t4                                  ON t3.Field32 = t4.Filed41                        WHERE ((t2.Field24 >= '')                                  AND t1.fId = t4.fId)) WHERE EXISTS (SELECT Field21, Field22               FROM Table2 t2                    INNER JOIN Table3 t3                         ON t3.Field31 = t2.Field23                    INNER JOIN Table4 t4                         ON t3.Field32 = t4.Filed41               WHERE ((t2.Field24 >= '')                                AND t1.fId = t4.fId)); ---------------------------------DB2 ------------------------------------------

UPDATE Table1 AS t1 SET (Field1,Field2) = (SELECT Field21, Field22                        FROM Table2 t2                             INNER JOIN Table3 t3                                  ON t3.Field31 = t2.Field23                             INNER JOIN Table4 t4                                  ON t3.Field32 = t4.Filed41                        WHERE ((t2.Field24 >= '')                                          AND t1.fId = t4.fId)) WHERE EXISTS (SELECT Field21, Field22               FROM Table2 t2                    INNER JOIN Table3 t3                         ON t3.Field31 = t2.Field23                    INNER JOIN Table4 t4                         ON t3.Field32 = t4.Filed41               WHERE ((t2.Field24 >= '')                                 AND t1.fId = t4.fId));



【本文地址】

公司简介

联系我们

今日新闻


点击排行

实验室常用的仪器、试剂和
说到实验室常用到的东西,主要就分为仪器、试剂和耗
不用再找了,全球10大实验
01、赛默飞世尔科技(热电)Thermo Fisher Scientif
三代水柜的量产巅峰T-72坦
作者:寞寒最近,西边闹腾挺大,本来小寞以为忙完这
通风柜跟实验室通风系统有
说到通风柜跟实验室通风,不少人都纠结二者到底是不
集消毒杀菌、烘干收纳为一
厨房是家里细菌较多的地方,潮湿的环境、没有完全密
实验室设备之全钢实验台如
全钢实验台是实验室家具中较为重要的家具之一,很多

推荐新闻


图片新闻

实验室药品柜的特性有哪些
实验室药品柜是实验室家具的重要组成部分之一,主要
小学科学实验中有哪些教学
计算机 计算器 一般 打孔器 打气筒 仪器车 显微镜
实验室各种仪器原理动图讲
1.紫外分光光谱UV分析原理:吸收紫外光能量,引起分
高中化学常见仪器及实验装
1、可加热仪器:2、计量仪器:(1)仪器A的名称:量
微生物操作主要设备和器具
今天盘点一下微生物操作主要设备和器具,别嫌我啰嗦
浅谈通风柜使用基本常识
 众所周知,通风柜功能中最主要的就是排气功能。在

专题文章

    CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭